/*
*  Copyright (C) 2009  Peter Kist & Jan Ripke
*
*  This program is free software: you can redistribute it and/or modify
*  it under the terms of the GNU General Public License as published by
*  the Free Software Foundation, either version 3 of the License, or
*  (at your option) any later version.
*
*  This program is distributed in the hope that it will be useful,
*  but WITHOUT ANY WARRANTY; without even the implied warranty of
*  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
*  GNU General Public License for more details.
*
*  You should have received a copy of the GNU General Public License
*  along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/

#ifndef __database_record_h
#define __database_record_h 1

#include <windows.h>
#include <mysql.h>

#include <string>


namespace galaxy {
	namespace database {

		class Database;

		class Record
		{
		public:
			Record(void);
			virtual ~Record(void);

			virtual const char * tableName () = 0;
			virtual const char * primaryKey () = 0;

			virtual int doInsert (Database& db) = 0;
			virtual bool doDelete (Database& db) = 0;
			virtual bool doUpdate (Database& db) = 0;
			/** read a single record using the primary key */
			virtual bool doSelect () = 0;

			// doQuery
			// doQueryUpdate
		};

	} // namespace database
} // namespace galaxy

#endif // __database_record_h
